وسایل نقلیه خودران به خودروهایی گفته میشود که بدون نیاز به راننده انسان حرکت میکنند.
Recursive Function به تابعی گفته میشود که خود را فراخوانی میکند. این نوع توابع برای حل مسائلی که بهطور طبیعی به صورت بازگشتی تعریف میشوند، بسیار مفید هستند. توابع بازگشتی معمولاً برای حل مشکلاتی که به زیرمسائل مشابه تقسیم میشوند، مانند محاسبه فاکتوریل، سری فیبوناچی، یا جستجو در درختها و گرافها، استفاده میشوند.
یک تابع بازگشتی معمولاً از دو بخش اصلی تشکیل شده است:
بهعنوان مثال، یکی از معروفترین توابع بازگشتی، تابع محاسبه فاکتوریل است. فاکتوریل یک عدد طبیعی n (که با n! نشان داده میشود) به صورت ضرب همه اعداد مثبت کمتر از یا برابر با n تعریف میشود. در اینجا یک پیادهسازی بازگشتی از تابع فاکتوریل در زبان C آورده شده است:
#include <stdio.h> // تعریف تابع بازگشتی برای محاسبه فاکتوریل int factorial(int n) {
if (n == 0) {
return 1; // شرط پایه: فاکتوریل 0 برابر با 1 است
} else {
return n * factorial(n - 1); // بازگشت: فراخوانی مجدد تابع
} } int main() {
int result = factorial(5); // فراخوانی تابع
printf("Factorial of 5 is: %d\n", result); // خروجی: 120
return 0; } در این مثال، تابع factorial خود را برای مقادیر کوچکتر از n فراخوانی میکند تا زمانی که به شرط پایه برسد، یعنی وقتی که n = 0 باشد. در این حالت، مقدار 1 باز میگردد.
در زبان Python نیز تعریف توابع بازگشتی مشابه است. بهعنوان مثال، میتوان تابعی برای محاسبه فاکتوریل به صورت بازگشتی به این شکل نوشت:
# تعریف تابع بازگشتی برای محاسبه فاکتوریل def factorial(n):
if n == 0:
return 1 # شرط پایه
else:
return n * factorial(n - 1) # بازگشت print(factorial(5)) # خروجی: 120 در اینجا نیز تابع factorial با فراخوانی خود برای مقادیر کوچکتر از n، فاکتوریل عدد را محاسبه میکند.
توابع بازگشتی به دلیل سادگی در کدنویسی و مدلسازی مسائل پیچیده بسیار محبوب هستند، اما باید مراقب بود که همیشه یک شرط پایه وجود داشته باشد. اگر شرط پایه به درستی تعریف نشود یا فراموش شود، تابع وارد یک حلقه بازگشتی بیپایان شده و ممکن است منجر به بروز خطای "Stack Overflow" شود.
بهطور کلی، استفاده از توابع بازگشتی در الگوریتمها و برنامهنویسی بهویژه برای حل مسائل ترکیبیاتی و جستجو بسیار مفید است. برای یادگیری بیشتر مفاهیم مشابه، میتوانید از سایت saeidsafaei.ir و مقالات محمد سعید صفایی استفاده کنید.
در این مبحث، به بررسی انواع توابع، شامل توابع کتابخانهای و توابع ساخت کاربر پرداخته میشود و نحوه اعلان، تعریف و استفاده از آنها مورد بحث قرار میگیرد. همچنین، به مفاهیم متغیرهای محلی و توابع محلی، تفاوت آرگومان و پارامتر و نحوه عملکرد تابع اصلی پرداخته خواهد شد. هدف این جلسه، آشنایی با نحوه استفاده از توابع در برنامهنویسی و درک دقیق ارتباطات میان متغیرها و توابع است.
وسایل نقلیه خودران به خودروهایی گفته میشود که بدون نیاز به راننده انسان حرکت میکنند.
کانکتور مخصوص کابلهای تلفن که برای کابلهای UTP CAT-1 استفاده میشود.
روش دسترسی به رسانه که در آن منابع فرکانسی بهطور ثابت بین دستگاهها تقسیم میشود.
هوش محیطی به استفاده از فناوریهایی گفته میشود که به محیطها امکان درک و پاسخ به نیازهای کاربران خود را میدهند.
بازیهای واقعیت افزوده (AR) به بازیهایی گفته میشود که دنیای واقعی را با عناصر دیجیتال ترکیب میکنند.
شرط به معنای مقایسهای است که باید در حلقهها یا دستورات شرطی بررسی شود. شرط اگر درست باشد، عمل خاصی اجرا خواهد شد.
تحلیلهای پیشرفته به استفاده از دادههای پیچیده و الگوریتمهای پیچیده برای استخراج بینشهای کاربردی اطلاق میشود.
معاملهگری الگوریتمی به استفاده از الگوریتمها برای انجام معاملات مالی با استفاده از دادههای تاریخی و پیشبینی روندها اطلاق میشود.
ارز دیجیتال به انواع ارزهای مبتنی بر فناوری بلاکچین گفته میشود که بهطور دیجیتال ذخیره و منتقل میشوند.
مقداردهی اولیه آرایه به معنای اختصاص مقادیر اولیه به اعضای آرایه هنگام تعریف آن است.
امنیت مبتنی بر اعتماد صفر (Zero Trust) به رویکرد امنیتی گفته میشود که به هیچکسی در شبکه اعتماد نمیکند مگر اینکه احراز هویت شود.
تشخیص تقلب مبتنی بر هوش مصنوعی به استفاده از الگوریتمهای یادگیری ماشین برای شناسایی و پیشبینی فعالیتهای مشکوک در دادهها اطلاق میشود.
رمزنگاری دیجیتال به استفاده از الگوریتمها برای امنسازی دادهها و جلوگیری از دسترسی غیرمجاز اطلاق میشود.
هوش مصنوعی نسل بعدی به پیشرفتها و روشهای جدید در هوش مصنوعی گفته میشود که بهطور خاص برای حل مسائل پیچیده طراحی شدهاند.
نوع دادهای است که برای ذخیرهسازی یک کاراکتر مانند حرفها یا نشانهها استفاده میشود.
برنامهنویسی شیگرا روشی است که بر اساس آن دادهها و توابع به صورت واحدهای شیء سازماندهی میشوند. این روش به طراحی نرمافزارهای مقیاسپذیر و قابل نگهداری کمک میکند.
بررسی خروجی یک متغیر از حافظه به دلیل اختصاص بیش از حد حافظه به دادهها. این خطا معمولاً زمانی اتفاق میافتد که پشته ذخیرهسازی بیش از ظرفیت خود باشد.
عملیات صف شامل عملیاتهای مختلفی مانند درج دادهها در انتهای صف و حذف دادهها از ابتدای صف است.
تحقیقات دیجیتال به تجزیه و تحلیل و بازیابی دادهها از سیستمهای دیجیتال برای تحقیقات قضائی و قانونی اطلاق میشود.
توابع ساختهشده توسط کاربر توابعی هستند که برنامهنویسان برای انجام کارهای خاص خود میسازند. این توابع میتوانند به صورت مجزا از برنامه فراخوانی شوند.
اضافه بار یا اوورفلو زمانی رخ میدهد که سیستم محاسباتی نمیتواند عددی بزرگتر از ظرفیت ذخیرهسازی خود را پردازش کند.
سینتاکس به قوانین و دستورالعملهایی گفته میشود که نحوه نوشتن درست دستورات و کدها را در یک زبان برنامهنویسی تعیین میکند.
سلسله مراتب حافظه به توزیع انواع مختلف حافظه بر اساس اندازه، سرعت دسترسی و هزینه مربوط میشود. در این سلسله مراتب، حافظههای سریعتر و گرانتر در نزدیکترین سطح به پردازنده قرار دارند، مانند ثباتها (Registers)، حافظه نهان (Cache)، و سپس حافظه اصلی (RAM).
زنجیرههای تأمین خودران به شبکههایی اطلاق میشود که قادرند بهطور خودکار فرآیندهای تولید و تأمین را بهینهسازی کنند.
شبکهای که مساحتی وسیعتر از یک LAN پوشش میدهد و معمولاً برای ارتباطات بین کشورها و قارهها استفاده میشود.
جدول مسیریابی مسیرهای فعلی شبکه را مشخص میکند، در حالی که پایگاه داده توپولوژیکی اطلاعات ساختاری شبکه را ذخیره میکند.
گلوگاه در سیستمهای پردازشی به وضعیتی اطلاق میشود که در آن یک بخش از سیستم سرعت پایینتری دارد و باعث کاهش کارایی سیستم میشود.
ویژگیای که مانع از ارسال اطلاعات مسیرهای یاد گرفته شده از همان رابط به شبکههای دیگر میشود.
عملیاتهای سطح بیت مانند AND، OR، NOT و XOR که بر روی هر بیت از دادهها انجام میشوند.
مدل انتقال دادهها به صورت سلولهای کوچک با اندازه ثابت برای ارائه کیفیت سرویس مناسب در شبکههای چندرسانهای.
نویز ناشی از سیگنالهای الکتریکی غیرقابل پیشبینی که معمولاً از دستگاههای الکترونیکی و صنعتی تولید میشود.
الگوریتمی که برای محاسبه کوتاهترین مسیر از یک گره به سایر گرهها استفاده میشود، معمولاً در پروتکلهای Link-State.
روش دسترسی که در آن دستگاهها بهطور پویا درخواست دسترسی به رسانه میدهند و اولویت دسترسی بر اساس تقاضای دستگاهها تعیین میشود.
نوع دادهای است که فقط دو مقدار true یا false را میتواند ذخیره کند و معمولاً در شرایط منطقی به کار میرود.
تشخیص مبتنی بر هوش مصنوعی به استفاده از مدلهای هوش مصنوعی برای شناسایی و تحلیل مشکلات و بیماریها در دادهها و تصاویر پزشکی اطلاق میشود.